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Digital Bus 



Field 

This invention relates to a digital bus and, more particularly to the 
synchronization of strobe or clock signals transmitted over the digital bus. 

5 Background 

A digital bus provides circuits and a transmission medium for exchanging 
information between digital systems. A digital bus typically couples two or more 
systems that communicate using clocked data. Clocked data is data that is accompanied 
by a clock signal. The clock signal defines a time when the clocked data is valid. In one 

10 example system, a first processor controlling a data storage device, such as a disk drive, 
communicates with a second processor, such as a central processing unit (CPU), by 
sending and receiving information over a digital bus. In another example system, a CPU 
communicates with a memory, such as a solid state memory, by sending information to 
the memory and receiving information from the memory over a digital bus. The memory 

15 may be located on a die that includes the processor or located on a die that is separate 
from the processor. 

Increasing the width of a bus connecting two digital systems generally increases 
the bandwidth of the bus. For example, early microprocessors typically transmitted and 
received information on four-bit and eight-bit buses, and generally supported only low 

20 bandwidth applications. Today, it is common to transmit information in digital systems 
on sixty-four bit buses, 128 bit buses, and 256 bit buses, all of which support high 
bandwidth applications. To reduce transmission errors, wide buses are subdivided into 
signaling groups. A signaling group typically comprises a plurality of data or 
information bits and an accompanying strobe or clock signal. A transition on the strobe 

25 or clock signal indicates that the accompanying data in the signaling group is valid. 
Unfortunately, because of manufacturing and electrical variations, such as strobe or 
clock transmission paths having different parasitic capacitances and strobe or clock driver 
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and receiver circuits having different delays in different strobe and clock paths, the strobe 
or clock signals for each of the signaling groups on a bus may not arrive at a common 
receiving system at the same time. When strobe or clock information arriving at a 
receiving system are not synchronized, the receiving system cannot efficiently process the 
5 received data. One solution to this problem of skewed strobe or clock signals is to design 
the receiving system on the digital bus for the worst case arrival times of the strobes. 
Unfortunately, designing a bus for the worst case arrival times decreases the overall 
bandwidth of the system. Another solution to this problem of skewed strobe or clock 
signals is to synchronize a clock at the receiving system to the transmission clocks. 
10 Unfortunately, it is difficult to design a circuit that synchronizes a clock to multiple out- 
of-phase clocks or strobes without significantly reducing the bandwidth of the digital bus. 
For these and other reasons there is a need for the present invention. 

Brief Description of the Drawings 
Figure 1 is a block diagram illustrating one embodiment of a digital bus according 
15 to the present invention; 

Figure 2 is a block diagram illustrating one embodiment of a receiver unit shown 
in Figure 1; 

Figure 3 is a block diagram illustrating one embodiment of a synchronizer unit 
shown in Figure 2; 

20 Figure 4 is a logic diagram of one embodiment of the synchronizer unit shown in 

Figure 3; 

Figure 5 is a timing diagram showing the generation of a synchronized reset 
signal in the synchronizer unit shown in Figure 4; 

Figure 6 is a timing diagram in which each of the WRITE CLOCK SIGNALS 0-3 
25 has a rising edge that leads the SAMPLE CLOCK SIGNAL following the release of the 
RESET SIGNAL; 

Figure 7 is a timing diagram in which the rising edge of the SAMPLE CLOCK 
SIGNAL leads each of the WRITE CLOCK SIGNALS 0-3 by 1-2 clock cycles; 
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Figure 8 is a timing diagram in which the rising edge of the SAMPLE CLOCK 
SIGNAL following the release of the RESET SIGNAL leads each of the WRITE 
CLOCK SIGNALS 0-3 by 0-1 clock cycles; 



5 



Figure 9 is a block diagram illustrating one embodiment of an integrated circuit 
including the digital bus shown in Figure 1 according to the teachings of the present 
invention; and 



Figure 10 is a flow diagram illustrating one embodiment of a method for 
transmitting and receiving information on the digital bus shown in Figure 1. 



10 



Detailed Description 



In the following detailed description of the invention, reference is made to the 
accompanying drawings which form a part hereof, and in which are shown, by way of 
illustration, specific embodiments of the invention which may be practiced. In the 
drawings, like numerals describe substantially similar components throughout the several 



art to practice the invention. Other embodiments may be utilized and structural, logical, 
and electrical changes may be made without departing from the scope of the present 
invention. The following detailed description is not to be taken in a limiting sense, and 
the scope of the present invention is defined only by the appended claims, along with the 

20 full scope of equivalents to which such claims are entitled. 

Figure 1 is a block diagram of one embodiment of a digital bus 101 according to 
the teachings of the present invention. The digital bus 101 includes a transmitter unit 
103, a transmission medium 105, and a receiver unit 107. The transmission medium 105 
couples the transmitter unit 103 to the receiver unit 107 and provides a path for 

25 exchanging information between the transmitter unit 1 03 and the receiver unit 1 07. 

The transmitter unit 103 is typically an electronic system capable of generating 
information in the form of digital signals that are transmitted to the receiver unit 107 over 
the transmission medium 105. Preferably, the transmitter unit 103 transmits a plurality of 
signaling groups. A signaling group includes one or more data signals or information bits 



15 



views. These embodiments are described in sufficient detail to enable those skilled in the 
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and an accompanying strobe or clock signal. A transition on the strobe or clock signal 
defines a time when the data signals or information contained in the signaling group is 
valid. In one exemplary embodiment of the present invention, the transmitter unit 103 is 
a processor, such as a microprocessor, a digital signal processor, a reduced instruction set 
5 processor, or a complex instruction set computing system. In an alternate exemplary 
embodiment, the transmitter unit 103 is a transceiver unit capable of transmitting and 
receiving information on the transmission medium 105. The present invention is not 
limited to a particular type of transceiver unit. Exemplary transceiver units suitable for 
use in connection with the present invention include processors and communications 

10 systems, such as cell phones and personal digital assistants. In still another exemplary 
embodiment, the transmitter 103 is a data storage device, such as a memory. Exemplary 
memories suitable for use in connection with the present invention include but are not 
limited to dynamic random-access memories, static random-access memories, 
programmable read only memories, and electrically programmable read-only memories. 

1 5 The transmission medium 105 provides a path for transmitting signals from the 

transmitter unit 103 to the receiver unit 107. In one exemplary embodiment of the 
present invention, the transmission medium 105 is fabricated from conductive elements 
that couple the transmitter unit 103 to the receiver unit 107. The present invention is not 
limited to use in connection with a particular type of conductive element. In one 

20 embodiment, the transmission medium 105 is fabricated from copper conductors formed 
on a substrate, such as on a circuit board. In an alternate embodiment, the transmission 
medium 105 is fabricated from copper alloy wires formed into a cable. In still another 
alternate embodiment, the transmission medium 105 is fabricated from a plurality of 
metal interconnects fabricated on a substrate, such as a semiconductor substrate or a 

25 ceramic substrate. Each of the plurality of metal interconnects is typically a thin, narrow 
metal layer fabricated on the substrate for the purpose of interconnecting electronic 
circuits. In another exemplary embodiment of the present invention, the transmission 
medium 105 comprises fiber optic cables or interconnects. In still another exemplary 
embodiment of the present invention, the transmission medium 105 comprises a free 
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space path. In this embodiment, the transmitter unit 103 and the receiver unit 107 can 
exchange information at frequencies not generally transmitted over a conductive material 
or a fiber optic cable. 

The receiver unit 107 is an electronic system capable of receiving information or 
5 data transmitted by the transmitter unit 103. In one embodiment, the receiver unit 107 
includes one or more first-in-first-out (FIFO) units 109 coupled to a synchronizer unit 
111. Each of the one or more FIFO units 109 is a buffer capable of storing information or 
data received from the transmitter unit 103. In one exemplary embodiment of the present 
invention, the receiver unit 107 includes a processor, such as a microprocessor, a digital 

10 signal processor, a reduced instruction set processor, or a complex instruction set 

computing system. In an alternate exemplary embodiment, the receiver unit 107 includes 
a transceiver unit capable of transmitting and receiving information over the transmission 
medium 105. The present invention is not limited to a particular type of transceiver unit. 
Exemplary transceiver units suitable for use in connection with the present invention 

15 include processors and communications systems, such as cell phones and personal digital 
assistants. In still another exemplary embodiment, the receiver unit 107 is a data storage 
device, such as a memory. Exemplary memories suitable for use in connection with the 
present invention include but are not limited to dynamic random-access memories, static 
random-access memories, programmable read only memories, and electrically 

20 programmable read-only memories. 

Figure 2 is a block diagram of one embodiment of the receiver unit 107 shown in 
Figure 1 . The receiver unit 1 07 includes the synchronizer unit 111 and the one or more 
FIFO units 109 coupled to the synchronizer unit 111. The synchronizer unit 111 receives 
as inputs a RESET SIGNAL at node 201, a SAMPLE CLOCK SIGNAL at node 203, and 

25 a plurality of WRITE CLOCK SIGNALS 0-3 at nodes 204-207. The receiver unit 107 
generates WRITE RESET SIGNALS 0-3 at nodes 209-212 of the synchronizer unit 111, 
and a READ RESET SIGNAL at node 214 of the synchronizer unit 111. The plurality of 
FIFO units 109 receive as inputs a plurality of DATA SIGNALS 0-3 at nodes 211-214, 
the plurality of WRITE CLOCK SIGNALS 0-3 at nodes 216-219, a plurality of WRITE 



00884.302US1 



5 



P9226 



RESET SIGNALS at nodes 221-224, the READ RESET SIGNAL at nodes 226-229, and 
the SAMPLE CLOCK SIGNAL at node 231-234. 

In operation, the plurality of FIFO units 109 receive the plurality of DATA 
SIGNALS 0-3 at the nodes 21 1-214 and the plurality of WRITE CLOCK SIGNALS 0-3 
5 at the nodes 216-219, as inputs from transmitter unit 103 (shown in Figure 1). Each of 
the plurality of WRITE CLOCK SIGNALS 0-3 received at the nodes 216-219 is 
associated with one or more data signals. For example, WRITE CLOCK SIGNAL 0 at 
the node 216 is associated with DATA SIGNAL 0 received by one of the one or more 
FIFO units 109 at the node 21 1 . A transition on any of the WRITE CLOCK SIGNALS 

10 0-3 at the nodes 216-219 defines a time when the associated data signal is valid. The 
plurality of WRITE CLOCK SIGNALS 0-3 at the nodes 216-219 clock the DATA 
SIGNALS 0-3 at the nodes 21 1-214 into a first stage of the FIFO units 109. The 
synchronizer unit 1 1 1 receives the RESET SIGNAL at the node 201, the SAMPLE 
CLOCK SIGNAL at the node 203, and the WRITE CLOCK SIGNALS 0-3 at the nodes 

1 5 209-2 1 2 and generates the READ RESET SIGNAL at the node 2 1 4 and the WRITE 

RESET SIGNALS 0-3 at the nodes 209-212. The RESET SIGNAL at the node 201 and 
the SAMPLE CLOCK SIGNAL at the node 203 are typicaly local signals. The 
frequency of the SAMPLE CLOCK SIGNAL at the node 203, in one embodiment, is 
about twice the frequency of the plurality of WRITE CLOCK SIGNALS 0-3. The READ 

20 RESET SIGNAL generated at the node 2 14 is positioned with respect to the plurality of 
WRITE RESET SIGNALS 0-3 at the nodes 209-212 and has a latency with respect to 
each of the plurality of WRITE RESET SIGNALS 0-3 at the nodes 209-212 of less than 
or equal to one clock cycle. A clock cycle is the time between successive rising edges of 
a clock signal or the time between successive falling edges of a clock signal. The READ 

25 RESET SIGNAL at the node 214 of the FIFO units 109 resets the DATA OUTPUT 
SIGNALS 0-3 at the nodes 226-229 of the FIFO unit 109. The SAMPLE CLOCK 
SIGNAL at the node 203 clocks the data last written into the plurality of FIFO units 109 
from the FIFO DATA SIGNALS 0-3 at the nodes 236-239 of the plurality of FIFO units 
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109. Finally, the WRITE RESET SIGNALS 0-3 at nodes 221-223 reset the data at the 
first stage of the FIFO units 109. 

Figure 3 is a block diagram of one embodiment of a synchronizer unit 1 1 1 shown 
in Figure 2. Synchronizer unit 111 comprises a first synchronizer unit 301, a second 
5 synchronizer unit 303, and a third synchronizer unit 305. The first synchronizer unit 301 
receives WRITE CLOCK SIGNALS 0-3 at node 307 and a RESET SIGNAL at node 312 
and generates a SYNCHRONIZED RESET SIGNAL at node 316. The WRITE CLOCK 
SIGNALS at node 314 are passed through the first synchronizer unit 301 from node 307. 
The second synchronizer unit 303 is coupled to the first synchronizer unit 30L The 

1 0 second synchronizer unit 303 receives the WRITE CLOCK SIGNALS 0-3 at node 3 1 8, 
the SYNCHRONIZED RESET SIGNAL at node 319, and generates WRITE RESET 
SIGNALS 0-3 at node 320, the WRITE RESET SIGNALS 0-3 (minus three gate delays) 
at node 322, and the WRITE RESET SIGNALS 0-3 (minus two gate delays) at node 324. 
The third synchronizer unit 305 is coupled to the second synchronizer unit 303. The third 

1 5 synchronizer unit 305 receives the WRITE RESET SIGNALS 0-3 at node 325, the 
WRITE RESET SIGNALS 0-3 (minus three gate delays) at node 326, the WRITE 
RESET SIGNALS 0-3 (minus two gate delays) at node 328, the SYNCHRONIZED 
RESET SIGNAL at node 330, and the SAMPLE CLOCK SIGNAL at node 332, and 
generates a READ RESET SIGNAL at node 334. The READ RESET SIGNAL at node 

20 334 is positioned with respect to the WRITE RESET SIGNALS 0-3 at node 320, and the 
READ RESET SIGNAL at node 334 has a latency with respect to the each of the WRITE 
RESET SIGNALS 0-3 at node 320 of less than or equal to one clock cycle. 

Figure 4 is a logic diagram of one embodiment of the synchronizer unit 1 1 1 
shown in Figure 3. The synchronizer unit 111 includes the first synchronizer unit 301, 

25 the second synchronizer unit 303, and the third synchronizer unit 305. 

The first synchronizer unit 301 includes four data paths. The first data path 
includes three serially connected D flip-flops 401-403. The second data path includes 
three serially connected D flip-flops 404-406. The third data path includes three serially 
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connected D flip-flops 407-409. And the fourth data path includes three serially 
connected D flip-flops 410-412. 

The first synchronizer unit 301 receives a plurality of clock signals, such as the 
WRITE CLOCK SIGNALS 0-3 at nodes 413-424, and the RESET SIGNAL at nodes 
5 425-428. In one embodiment, the plurality of clock signals has a frequency of between 
about one gigahertz and about five gigahertz. The plurality of clock signals are 
preferably two-phase clocks or a pair of complementary clock signals. A two-phase 
clock or a pair of complementary clock signals includes a first clock signal and a second 
clock signal. The first clock signal and the second clock signal have the same frequency 

10 but are 180 degrees out of phase (one phase is designated phase 0 and one phase is 
designated phase 1). In one embodiment of the present invention, the pair of 
complementary clock signals have a skew of less than 90 degrees. The D flip-flops 401- 
403 in the first data path receive the WRITE CLOCK SIGNAL 0 (phase 0) and the 
WRITE CLOCK SIGNAL 0 (phase 1). The D flip-flops 401 and 403 receive the WRITE 

15 CLOCK SIGNAL 0 (phase 0) at nodes 41 3 and 415, and D flip-flop 402 receives WRITE 
CLOCK SIGNAL 0 (phase 1) at node 414. The D flip-flops 404-406 in the second data 
path receive the WRITE CLOCK SIGNAL 1 (phase 0) and the WRITE CLOCK 
SIGNAL 1 (phase 1). The D flip-flops 404 and 406 receive the WRITE CLOCK 
SIGNAL 1 (phase 0) at nodes 416 and 418, and D flip-flop 405 receives WRITE CLOCK 

20 SIGNAL 1 (phase 1) at node 417. The D flip-flops 407-409 in the third data path receive 
the WRITE CLOCK SIGNAL 2 (phase 0) and the WRITE CLOCK SIGNAL 2 (phase 1). 
The D flip-flops 407 and 409 receive WRITE CLOCK SIGNAL 2 (phase 0) at nodes 419 
and 421, and the D flip-flop 408 receives WRITE CLOCK SIGNAL 2 (phase 1) at node 
420. The D flip-flops 410-412 in the fourth data path receive the WRITE CLOCK 

25 SIGNAL 3 (phase 0) and the WRITE CLOCK SIGNAL 3 (phase 1). The D flip-flops 

410 and 412 receive the WRITE CLOCK SIGNAL 3 (phase 0) at nodes 422 and 424, and 
the D flip-flop 411 receives the WRITE CLOCK SIGNAL 3 (phase 1) at node 423. Each 
of the D flip-flops 401, 404, 407, and 410 receive the RESET SIGNAL at nodes 425-428. 
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In operation, the first synchronizer unit 301 generates SYNCHRONIZED RESET 
SIGNALS 0-3 at nodes 430-433, and a SYNCHRONIZED RESET SIGNAL at node 435. 
The SYNCHRONIZED RESET SIGNALS 0-3 at the nodes 430-433 are generated by 
clocking the RESET SIGNAL at the nodes 425-428 through the first data path, the 
5 second data path, the third data path, and the fourth data path using the WRITE CLOCK 
SIGNALS 0-3 (phase 0) and the WRITE CLOCK SIGNALS 0-3 (phase 1). The 
SYNCHRONIZED RESET SIGNALS 0-3 at nodes 430-433 are ORed together at OR 
gate 437 to generate the SYNCHRONIZED RESET SIGNAL are the node 435. 
Figure 5 is a timing diagram 501 showing the generation of the 

10 SYNCHRONIZED RESET SIGNAL (node 435 in Figure 4) 503. The timing diagram 
501 includes WRITE CLOCK SIGNALS 0-3 (nodes 413, 416, 419, and 422 in Figure 4) 
505-508, RESET SIGNAL (nodes 425-428 in Figure 4) 510, SYNCHRONIZED RESET 
SIGNALS 0-3 (nodes 430-433 in Figure 4) 512-515, and the SYNCHRONIZED RESET 
SIGNAL (node 435 in Figure 4) 503. The SYNCHRONIZED RESET SIGNAL 503 is 

1 5 generated by ORing the SYNCHRONIZED RESET SIGNALS 0-3 5 1 2-5 1 5. As can be 
seen from the timing diagram 501, a falling edge 517 of the WRITE CLOCK SIGNAL 0 
triggers a rising edge 519 of the SYNCHRONIZED RESET SIGNAL 0 512, which 
triggers a rising edge 521 of the SYNCHRONIZED RESET SIGNAL 503, which is 
ahead of each rising edge 523 of each of the WRITE CLOCK SIGNALS 0-3 505-508 

20 that occur after the rising edge 521 of the SYNCHRONIZED RESET SIGNAL 503. 

Referring again to Figure 4, the second synchronizer unit 303 includes four data 
paths. The first data path includes five serially connected D flip-flops 438-442. The 
second data path includes five serially connected D flip-flops 443-447. The third data 
path includes five serially connected D flip-flops 448-452. And the fourth data path 

25 includes five serially connected D flip-flops 453-457. 

The second synchronizer unit 303 receives the WRITE CLOCK SIGNALS 0-3 at 
D flip-flops 438-457 and the SYNCHRONIZED RESET SIGNAL at D flip-flops 438, 
443, 448 and 453. The D flip-flops 438-442 in the first data path receive the WRITE 
CLOCK SIGNAL 0 (phase 0) and the WRITE CLOCK SIGNAL 0 (phase 1). The D 
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flip-flops 443-447 in the second data path receive the WRITE CLOCK SIGNAL 1 (phase 
0) and the WRITE CLOCK SIGNAL 1 (phase 1). The D flip-flops 448-452 in the third 
data path receive the WRITE CLOCK SIGNAL 2 (phase 0) and the WRITE CLOCK 
SIGNAL 2 (phase 1). The D flip-flops 453-457 in the fourth data path receive the 
5 WRITE CLOCK SIGNAL 3 (phase 0) and the WRITE CLOCK SIGNAL 3 (phase 1). 
Each of the D flip-flops 438, 443, 448, and 453 receive the SYNCHRONIZED RESET 
SIGNAL generated at the first synchronizer unit 301 at node 435. 

In operation, the second synchronizer unit 303 generates the WRITE RESET 
SIGNALS 0-3 (minus three gate delays) at nodes 459-462, the WRITE RESET 

1 0 SIGNALS 0-3 (minus two gate delays) at nodes 464-467, and WRITE RESET SIGNALS 
0-3 at nodes 469-472. The WRITE RESET SIGNALS 0-3 (minus three gate delays) at 
nodes 459-462, the WRITE RESET SIGNALS 0-3 (minus two gate delays) at nodes 464- 
467, and the WRITE RESET SIGNALS 0-3 at nodes 469-472 are generated by clocking 
the SYNCHRONIZED RESET SIGNAL at the node 435 through the first data path, the 

15 second data path, the third data path, and the fourth data path using the WRITE CLOCK 
SIGNALS 0-3 (phase 0) and the WRITE CLOCK SIGNALS 0-3 (phase 1). 

The third synchronizer 305 includes a first plurality of set-reset flip-flops 473- 
476, a second plurality of set-reset flip-flops 477-480, a multiplexor 48 1 , and a plurality 
of serially connected D flip-flops 482-490. The first plurality of set-reset flip-flops 473- 

20 476 are coupled to a first control port of the multiplexor 481 through an OR gate 49 1 , and 
the second plurality of set-reset flip-flops 477-480 are coupled to a second control port of 
the multiplexor 481 through an OR gate 492. The multiplexor 481 couples D flip-flop 
486, D flip-flop 487, or D flip-flop 488 to the D flip-flop 489 in response to signals at the 
first control port and the second control port of the multiplexor 48 1 . The inputs ports of 

25 the multiplexor 48 1 are coupled to the D flip-flop 486, the D flip-flop 487, and the D flip- 
flop 488. The multiplexor 481 controls the number of D flip-flops in the data path 
between the D flip-flop 484 and the D flip-flop 489. 

Each of the set inputs of the first plurality of set-reset flip-flops 473-476 is 
coupled to the WRITE RESET SIGNALS (0-3) (minus three gate delays) at the nodes 
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459-462 of the second synchronizer unit 303. Each of the reset inputs of the first 
plurality of set-reset flip-flops 473-476 is coupled to an output port of the D flip-flop 483. 
The output ports of the set-reset flip-flops 473-476 are coupled to the input port of the 
OR gate 491, and the output port of the OR gate 491 is coupled to a first control input of 
5 the multiplexor 481. 

Each of the set inputs of the second plurality of set-reset flip-flops 477-480 is 
coupled to the WRITE RESET SIGNALS (0-3) (minus two gate delays) at the nodes 
464-467 of the second synchronizer unit 303. Each of the reset inputs of the second 
plurality of set-reset flip-flops 477-480 is coupled to an output port of the D flip-flop 485. 

1 0 The output ports of the set-reset flip-flops 477-480 are coupled to the input port of the 

OR gate 492, and the output port of the OR gate 492 is coupled to a second control input 
of the multiplexor 481 . 

A data port of the D flip-flop 482 of the plurality of serially connected flip-flops 
482-490 is coupled to the SYNCHRONIZED RESET SIGNAL at node 435 of the first 

1 5 synchronizer unit 30 1 . Each of the clock inputs of the D flip-flops 482-490 in the 

plurality of serially connected D flip-flops 482-490 is coupled to the SAMPLE CLOCK 
SIGNAL. 

In operation, the SAMPLE CLOCK SIGNAL clocks the SYNCHRONIZED 
RESET SIGNAL at node 435 through the serially connected D flip-flops 482-490. When 

20 the SYNCHRONIZED RESET SIGNAL at node 435 is clocked to the output of the D 
flip-flop 483, each of the first plurality of set-reset flip-flops 473-476 is set. When the 
SYNCHRONIZED RESET SIGNAL at node 435 is clocked to the output of the D flip- 
flop 485, each of the second plurality of set-reset flip-flops 477-480 is set. The WRITE 
RESET SIGNALS (0-3) (minus three gate delays) at nodes 459-462 reset each of the first 

25 plurality of set-reset flip-flops 473-476. The WRITE RESET SIGNALS (0-3) (minus 

two gate delays) at nodes 464-467 reset each of the second plurality of set-reset flip-flops 
477-480. When at least one of the first plurality of set-reset flip-flops 473-476 is set, and 
at least one of the second plurality of set-reset flip-flops 477-480 is set, the output of the 
D flip-flop 488 is coupled by the multiplexor 481 to the input of the D flip-flop 489. 
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When at least one of the first plurality of set-reset flip-flops 473-476 is set, and none of 
the second plurality of set-reset flip-flops 477-480 is set, the output of the D flip-flop 487 
is coupled by the multiplexor 481 to the input of the D flip-flop 489. When none of the 
first plurality of set-reset flip-flops 473-476 is set, the output of the D flip-flop 486 is 
5 coupled by the multiplexor 481 to the input of the D flip-flop 489. By controlling the 
number of D flip-flops in the data path between the D flip-flop 484 and the D flip-flop 
489, the latency of the READ RESET SIGNAL at node 493 with respect to each of the 
WRITE RESET SIGNALS 0-3 at nodes 469-472 can be maintained at one clock cycle or 
less. 

10 Figures 6, 7, and 8 illustrate three example timing diagrams showing relationships 

between a SAMPLE CLOCK SIGNAL and WRITE CLOCK SIGNALS 0-3, which can 
result in a latency between WRITE RESET SIGNALS 0-3 and the READ RESET 
SIGNAL of between 1 and 2 clock cycles. Figure 6 shows a timing diagram 601 in 
which each of the WRITE CLOCK SIGNALS 0-3 603-606 has a rising edge 608 that 

1 5 leads the SAMPLE CLOCK SIGNAL 609 following the release of the RESET SIGNAL 
610. Latency 61 1 between WRITE RESET SIGNALS 0-3 613 and READ RESET 
SIGNAL 615 is between 1 and 2 clock cycles. Figure 7 shows a timing diagram 701 in 
which a rising edge 702 of the SAMPLE CLOCK SIGNAL 703 leads each of the WRITE 
CLOCK SIGNALS 0-3 705-708 by 1-2 clock cycles. Latency 71 1 between WRITE 

20 RESET SIGNALS 0-3 713 and READ RESET SIGNAL 71 5 is between 1 and 2 clock 

cycles. Figure 8 shows a timing diagram 801 in which a rising edge 803 of the SAMPLE 
CLOCK SIGNAL 804 following the release of the RESET SIGNAL 805 leads each of 
the WRITE CLOCK SIGNALS 0-3 807-810 by 0-1 clock cycles. Latency 811 between 
WRITE RESET SIGNALS 0-3 813 and READ RESET SIGNAL 815 is between 1 and 2 

25 clock cycles. The synchronizer unit 1 1 1 processes the SAMPLE CLOCK SIGNAL and 
the WRITE CLOCK SIGNALS 0-3 having the timing relationships shown in Figures 6, 
7, and 8 and generates a READ RESET SIGNAL having a latency with respect to the 
WRITE RESET SIGNALS 0-3 of between 0 and 1 clock cycles. 
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Figure 9 is a block diagram of one embodiment of an integrated circuit 901 
capable of transmitting and receiving information according to the teachings of the 
present invention. Integrated circuit 901 includes digital bus 101 (described above and 
shown in Figure 1). Each of the elements of the digital bus 101 including the transmitter 
5 unit 103 (shown in Figure 1), the transmission medium 105 (shown in Figure 1), and the 
receiver unit 107 (shown in Figure 1) can be fabricated using integrated circuit 
manufacturing processes known to those skilled in the art. In one embodiment, the 
digital bus 101 are fabricated on a single substrate, such as silicon, and the transmission 
medium 105 comprises a plurality of copper interconnects. Integrated circuit 901 and 

10 digital bus 101 are not limited to being fabricated using a particular integrated circuit 

manufacturing process. Any process or combination of processes capable of fabricating 
logic circuits is suitable for use in connection with the present invention. Exemplary 
integrated circuit manufacturing processes suitable for use in connection with the present 
invention include complementary metal-oxide semiconductor (CMOS) processes, bipolar 

15 processes, and combinations of bipolar and CMOS processes. 

Figure 10 is a flow diagram 1000 illustrating one embodiment of a method for 
forming a synchronized reset signal. The method comprises synchronizing a first reset 
signal to a plurality of clock signals to form a synchronized reset signal (block 1001), 
synchronizing the synchronized reset signal to the plurality of clock signals to form a 

20 plurality of write reset signals (block 1003), and synchronizing the synchronized reset 

signal to a sample clock signal to form a read reset signal having a latency with respect to 
each of the plurality of write reset signals of less than or equal to one clock cycle (block 
1005). 

Although specific embodiments have been described and illustrated herein, it will 
25 be appreciated by those skilled in the art, having the benefit of the present disclosure, that 
any arrangement which is intended to achieve the same purpose may be substituted for a 
specific embodiment shown. This application is intended to cover any adaptations or 
variations of the present invention. Therefore, it is intended that this invention be limited 
only by the claims and the equivalents thereof. 
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What is claimed is: 



1 1, A digital bus comprising: 

2 a transmitter unit capable of generating a plurality of clock signals; 

3 a receiver unit comprising: 

4 one or more first-in-first-out (FIFO) units; and 

5 a synchronizer unit coupled to the one or more FIFO units, the 

6 synchronizer unit adapted to receive the plurality of clock signals, a sample clock 

7 signal, and a reset signal and to generate a plurality of write reset signals and a 

8 read reset signal, wherein each of the plurality of write reset signals has a latency 

9 with respect to the read reset signal of less than or equal to one clock cycle; and 

10 a transmission medium to couple the plurality of clock signals from the 

1 1 transmitter unit to the receiver unit. 

1 2. The digital bus of claim 1, wherein the transmitter unit comprises a transceiver. 

1 3 . The digital bus of claim 2, wherein the transceiver comprises a processor. 

1 4. The digital bus of claim 1 , wherein each of the plurality of clock signals 

2 comprises a pair of complementary clock signals. 

1 5. The digital bus of claim 4, wherein the pair of complementary clock signals have 

2 a skew of less than 90 degrees. 

1 6. The digital bus of claim 4, wherein each of the plurality of clock signals has a 

2 frequency of between about 500 megahertz and about five gigahertz. 

1 7. The digital bus of claim 1, wherein the transmission medium comprises a cable. 
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1 8 . The digital bus of claim 1 , wherein each of the plurality of clock signals has a 

2 clock frequency and the sample clock has a sample clock frequency that is about twice 

3 the clock frequency. 

1 9. The digital bus of claim 1, wherein the transmission medium comprises a plurality 

2 of metal interconnects formed on a substrate. 

1 1 0. The digital bus of claim 1 , wherein the transmission medium comprises free 

2 space. 

1 11. The digital bus of claim 1 , wherein the receiver unit comprises a memory unit. 

1 12. The digital bus of claim 1 1 , wherein the memory unit comprises a dynamic 

2 random access memory. 

1 13. An integrated circuit comprising: 

2 a transmitter unit capable of generating a plurality of clock signals; 

3 a receiver unit comprising: 

4 one or more first-in-first-out (FIFO) units; and 

5 a synchronizer unit coupled to the one or more FIFO units, the 

6 synchronizer unit adapted to receive the plurality of clock signals and a sample 

7 clock signal and to generate a plurality of write reset signals and a read reset 

8 signal, wherein each of the plurality of write reset signals has a latency with 

9 respect to the read reset signal of less than or equal to one clock cycle; and 

10 a transmission medium to couple the plurality of clock signals from the 

1 1 transmitter unit to the receiver unit. 

1 14. The integrated circuit of claim 13, wherein the transmitter unit, the receiver unit, 

2 and the transmission medium are fabricated on a single substrate. 
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1 15. The integrated circuit of claim 14, wherein the single substrate is silicon. 

1 16, The integrated circuit of claim 13, wherein the transmission medium comprises a 

2 plurality of copper interconnects. 

1 1 7. The integrated circuit of claim 13, wherein the transmitter unit comprises a 

2 memory unit. 

1 18. The integrated circuit of claim 1 7, wherein the memory unit comprises a dynamic 

2 random access memory. 

1 19. The integrated circuit of claim 17, wherein the memory unit comprises a static 

2 random access memory. 

1 20. A synchronizer unit comprising: 

2 a logic circuit adapted to receive a plurality of clock signals, a reset signal, and a 

3 sample clock signal and to generate a synchronized reset signal synchronized to the reset 

4 signal, a plurality of write reset signals, and a read reset signal synchronized to the 

5 plurality of write reset signals, the read reset signal having a latency with respect to each 

6 of the plurality of write reset signals of less than or equal to one clock cycle. 

1 21. The synchronizer unit of claim 20, wherein the logic circuit comprises 

2 complementary metal-oxide semiconductor logic circuits. 

1 22. The synchronizer unit of claim 21 , wherein the logic circuit comprises a plurality 

2 logic gates having a delay of less than about two nanoseconds. 
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1 23 . A synchronizer unit comprising: 

2 a first synchronizer unit to receive a plurality of clock signals and a reset signal 

3 and to generate a synchronized reset signal; 

4 a second synchronizer unit to receive the plurality of clock signals and the 

5 synchronized reset signal and to generate a plurality of write reset signals; and 

6 a third synchronizer unit to receive a sample clock signal, the synchronized reset 

7 signal, and the plurality of write reset signals and to generate a read reset signal having a 

8 latency with respect to each of the write reset signals of less than or equal to one clock 

9 cycle. 

1 24. The synchronizer unit of claim 23, wherein the first synchronizer unit comprises a 

2 plurality of clock signal paths, wherein each of the plurality of clock signal paths 

3 comprises a plurality of serially connected flip-flops. 

1 25. The synchronizer unit of claim 24, further comprising an OR gate coupled to each 

2 of the plurality of clock signal paths, the OR gate having an output node providing the 

3 synchronized reset signal. 

1 26. The synchronizer unit of claim 24, wherein the second synchronizer unit 

2 comprises a plurality of clock signal paths, wherein each of the plurality of clock signal 

3 paths comprises a plurality of serially connected flip-flops. 

1 27. A method of forming a read reset signal, the method comprising: 

2 synchronizing a first reset signal to a plurality of clock signals to form a 

3 synchronized reset signal; 

4 synchronizing the synchronized reset signal to the plurality of clock signals to 

5 form a plurality of write reset signals; and 
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6 synchronizing the synchronized reset signal to a sample clock signal to form a 

7 read reset signal having a latency with respect to each of the plurality of write reset 

8 signals of less than or equal to one clock cycle. 

1 28. The method of claim 27, wherein synchronizing a first reset signal to a plurality of 

2 clock signals to form a synchronized reset signal comprises: 

3 clocking the first reset signal into a plurality of parallel flip-flops using the 

4 plurality of clock signals to clock each of the plurality of parallel flip-flops to form a 

5 plurality of clocked reset signals; and 

6 ORing the plurality of clocked reset signals to form the synchronized reset signal. 

29. The method of claim 27, wherein synchronizing the synchronized reset signal to 
the plurality of clock signals to form a plurality of write reset signals comprises: 

clocking the synchronized reset signal into a plurality of parallel flip-flops using 
the plurality of clock signals to clock each of the plurality of parallel flip-flops to form 
the plurality of write reset signals. 

30. The method of claim 27, wherein synchronizing the synchronized reset signal to a 
sample clock signal to form a read reset signal having a latency with respect to each of 
the plurality of write reset signals of less than or equal to one clock cycle comprises: 

adjusting a number of flip-flops in a signal path such that the read reset signal 
with respect to each of the plurality of write signals has a latency of less than or equal to 
one clock cycle. 
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Abstract 

A digital bus includes a transmitter unit, a receiver unit, and a transmission 
medium to couple the transmitter unit to the receiver unit and to provide a path for 
exchanging information between the transmitter unit and the receiver unit. The receiver 
unit includes a first-in-first-out (FIFO) unit and a synchronizer unit for receiving 
information from the transmitter unit. The synchronizer unit receives a plurality of write 
clock signals and a reset signal and generates a read reset signal positioned with respect 
to the plurality write clock signals and a sample clock signal. The read reset signal has a 
latency with respect to each of the plurality of write reset signals of between 0 and 1 
clock cycles. 
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a patent is sought on the invention entitled: DIGITAL BUS . 

The specification of which is attached hereto. 
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(a) A patent by its very nature is affected with 3 public interest. The public interest is best served, and the most effective patent 
examination occurs when, at the time an application is being examined, the Office is aware of and evaluates the teachings of all information 
material to patentability. Each individual associated with the filing and prosecution of a patent application has a duty of candor and good 
faith in dealing with the Office, which includes a duty to disclose to the Office all information known to that individual to be material to 
patentability as defined hi this section. The duty to disclose information exists with respect to each pending claim until the claim is canceled 
or withdrawn from consideration, or the application becomes abandoned Information material to the patentability of a claim that is 
canceled or withdrawn from consideration need not be submitted if the information is not material to the patentability of any claim 
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patlltabiiity, 
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( 1 ) Each inventor named in the application: 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the application and who is 
associated with the inventor, with the assignee ot with anyone to whom there is an obligation to assign the application. 

(d) Individuals other than the attorney, agent or inventor may comply with this section by disclosing information to the attorney, 
agent, or inventor* 



